<template>
  <div class="user-wrapper" :class="theme">
    <!-- update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
    <!-- update-begin author:sunjianlei date:20191@20 for: 解决全局样式冲突的问题 -->
    <!-- <span class="action" @click="showClick">
      <a-icon type="search"></a-icon>
    </span> -->
    <!-- update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件，在手机端呈现出弹出框 -->
    <!-- <component :is="searchMenuComp" v-show="searchMenuVisible || isMobile()" class="borders" :visible="searchMenuVisible" title="搜索菜单" :footer="null" @cancel="searchMenuVisible=false">
      <a-select
        class="search-input"
        showSearch
        :showArrow="false"
        placeholder="搜索菜单"
        optionFilterProp="children"
        :filterOption="filterOption"
        :open="isMobile()?true:null"
        :getPopupContainer="(node) => node.parentNode"
        :style="isMobile()?{width: '100%',marginBottom:'50px'}:{}"
        @change="searchMethods"
        @blur="hiddenClick"
      >
        <a-select-option v-for="(site,index) in searchMenuOptions" :key="index" :value="site.id">{{site.meta.title}}</a-select-option>
      </a-select>
    </component> -->
    <!-- update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件，在手机端呈现出弹出框 -->
    <!-- update-end author:sunjianlei date:20191220 for: 解决全局样式冲突的问题 -->
    <!-- update_end  author:zhaoxin date:20191129 for: 做头部菜单栏导航 -->
    <!-- <header-notice class="action"/> -->
    <a-dropdown>
      <span class="action action-full ant-dropdown-link user-dropdown-menu">
        <!-- <a-avatar class="avatar" size="small" :src="getAvatar()"/> -->
        <span v-if="isDesktop()">欢迎您，{{ userInfo().realName }}</span>
      </span>
      <a-menu slot="overlay" class="user-dropdown-menu-wrapper">
        <!-- <a-menu-item key="1">
          <router-link :to="{ name: 'account-settings-base' }">
            <a-icon type="setting"/>
            <span>账户设置</span>
          </router-link>
        </a-menu-item> -->
        <a-menu-item v-if="false" key="3" @click="systemSetting">
          <a-icon type="tool" />
          <span>系统设置</span>
        </a-menu-item>
        <a-menu-item key="4" @click="updatePassword">
          <a-icon type="setting" />
          <span>密码修改</span>
        </a-menu-item>
        <!--       <a-menu-item key="5" @click="updateCurrentDepart" v-if="orgList().length > 1">-->
        <!--          <a-icon type="cluster"/>-->
        <!--          <span>切换部门</span>-->
        <!--        </a-menu-item>-->
        <!-- <a-menu-item key="6" @click="clearCache">
          <a-icon type="sync"/>
          <span>清理缓存</span>
        </a-menu-item> -->
        <!-- <a-menu-item key="2" disabled>
          <a-icon type="setting"/>
          <span>测试</span>
        </a-menu-item>
        <a-menu-divider/>
        <a-menu-item key="3">
          <a href="javascript:;" @click="handleLogout">
            <a-icon type="logout"/>
            <span>退出登录</span>
          </a>
        </a-menu-item>-->
      </a-menu>
    </a-dropdown>
    <!-- <div class="action" v-show="false">
      <a class="logout_title" href="javascript:;" @click="toClient">
        <a-icon type="home" />
        <span>&nbsp;切换客户端</span>
      </a>
    </div>
    <div class="action">
      <a class="logout_title" href="javascript:;" @click="handleLogout">
        <a-icon type="logout" />
        <span v-if="isDesktop()">&nbsp;退出登录</span>
      </a>
    </div> -->

    <!-- 922设置 开始 -->
    <a-dropdown style="margin-right: 10px">
      <span
        class="action action-full ant-dropdown-link user-dropdown-menu"
        style="margin-left: 10px"
      >
        <a-icon type="logout" />
      </span>
      <a-menu slot="overlay">
        <a-menu-item key="3" @click="toClient">
          <a-icon type="home" />
          <span>切换客户端</span>
        </a-menu-item>
        <a-menu-item key="4" @click="handleLogout">
          <a-icon type="logout" />
          <span>退出登录</span>
        </a-menu-item>
      </a-menu>
    </a-dropdown>
    <!-- 922设置 结束 -->

    <depart-select
      ref="departSelect"
      :closable="true"
      title="部门切换"
    ></depart-select>
    <user-password ref="userPassword"></user-password>
    <setting-drawer
      ref="settingDrawer"
      :closable="true"
      title="系统设置"
    ></setting-drawer>
  </div>
</template>

<script>
import HeaderNotice from "./HeaderNotice";
import UserPassword from "./UserPassword";
import SettingDrawer from "@/components/setting/SettingDrawer";
import DepartSelect from "./DepartSelect";
import { mapActions, mapGetters, mapState } from "vuex";
import { mixinDevice } from "@/utils/mixin.js";
import { getFileAccessHttpUrl } from "@/api/manage";
import Vue from "vue";
import eventBus from "../eventBus.js";
import { USER_INFO } from "@/store/mutation-types";
// import Vue from 'vue'
// import { UI_CACHE_DB_DICT_DATA } from "@/store/mutation-types"

export default {
  name: "UserMenu",
  mixins: [mixinDevice],
  data() {
    return {
      // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
      searchMenuOptions: [],
      searchMenuComp: "span",
      searchMenuVisible: false,
      // update-begin author:sunjianlei date:20200219 for: 头部菜单搜索规范命名 --------------
    };
  },
  components: {
    HeaderNotice,
    UserPassword,
    DepartSelect,
    SettingDrawer,
  },
  props: {
    theme: {
      type: String,
      required: false,
      default: "dark",
    },
  },
  /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
  created() {
    let lists = [];
    this.searchMenus(lists, this.permissionMenuList);
    this.searchMenuOptions = [...lists];
  },
  computed: {
    ...mapState({
      // 后台菜单
      permissionMenuList: (state) => state.user.permissionList,
    }),
  },
  /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
  watch: {
    // update-begin author:sunjianlei date:20200219 for: 菜单搜索改为动态组件，在手机端呈现出弹出框
    device: {
      immediate: true,
      handler() {
        this.searchMenuVisible = false;
        this.searchMenuComp = this.isMobile() ? "a-modal" : "span";
      },
    },
    // update-end author:sunjianlei date:20200219 for: 菜单搜索改为动态组件，在手机端呈现出弹出框
  },
  methods: {
    /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    showClick() {
      this.searchMenuVisible = true;
    },
    hiddenClick() {
      this.shows = false;
    },
    /* update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    ...mapActions(["Logout"]),
    ...mapGetters(["avatar", "userInfo", "orgList"]),
    getAvatar() {
      return getFileAccessHttpUrl(this.avatar());
    },
    toClient() {
      this.$router
        .push({
          path: "/client/home",
        })
        .catch(() => {
          console.log("登录客户端出错,这个错误从哪里来的");
        });
    },
    handleLogout() {
      const that = this;

      this.$confirm({
        title: "提示",
        content: "真的要注销登录吗 ?",
        onOk() {
          return that
            .Logout({})
            .then(() => {
              Vue.ls.remove(USER_INFO);
              eventBus.$emit("logout", "logout");
              // update-begin author:wangshuai date:20200601 for: 退出登录跳转登录页面
              that.$router.push({ path: "/user/login" });
              // update-end author:wangshuai date:20200601 for: 退出登录跳转登录页面
              //window.location.reload()
            })
            .catch((err) => {
              that.$message.error({
                title: "错误",
                description: err.message,
              });
            });
        },
        onCancel() {},
      });
    },
    updateCurrentDepart() {
      this.$refs.departSelect.show();
    },
    updatePassword() {
      console.log(this.userInfo());
      let username = this.userInfo().loginName;
      this.$refs.userPassword.show(username);
    },
    systemSetting() {
      this.$refs.settingDrawer.showDrawer();
    },
    /* update_begin author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    searchMenus(arr, menus) {
      for (let i of menus) {
        if (!i.hidden && "layouts/RouteView" !== i.component) {
          arr.push(i);
        }
        if (i.children && i.children.length > 0) {
          this.searchMenus(arr, i.children);
        }
      }
    },
    filterOption(input, option) {
      return (
        option.componentOptions.children[0].text
          .toLowerCase()
          .indexOf(input.toLowerCase()) >= 0
      );
    },
    // update_begin author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
    searchMethods(value) {
      let route = this.searchMenuOptions.filter((item) => item.id === value)[0];
      if (
        route.meta.internalOrExternal === true ||
        route.component.includes("layouts/IframePageView")
      ) {
        window.open(route.meta.url, "_blank");
      } else {
        this.$router.push({ path: route.path });
      }
      this.searchMenuVisible = false;
    },
    // update_end author:sunjianlei date:20191230 for: 解决外部链接打开失败的问题
    /*update_end author:zhaoxin date:20191129 for: 做头部菜单栏导航*/
    /*update_begin author:liushaoqian date:20200507 for: 刷新缓存*/
    // clearCache(){
    //   getAction("sys/dict/refleshCache").then((res) => {
    //     if (res.success) {
    //       //重新加载缓存
    //       getAction("sys/dict/queryAllDictItems").then((res) => {
    //         if (res.success) {
    //           Vue.ls.remove(UI_CACHE_DB_DICT_DATA)
    //           Vue.ls.set(UI_CACHE_DB_DICT_DATA, res.result, 7 * 24 * 60 * 60 * 1000)
    //         }
    //       })
    //       this.$message.success("刷新缓存完成！");
    //     }
    //   }).catch(e=>{
    //     this.$message.warn("刷新缓存失败！");
    //     console.log("刷新失败",e)
    //   })
    // }
    /*update_end author:liushaoqian date:20200507 for: 刷新缓存*/
  },
};
</script>

<style lang="less" scoped>
/* update_begin author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
/* update-begin author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
.user-wrapper .search-input {
  width: 180px;
  color: inherit;

  /deep/ .ant-select-selection {
    background-color: inherit;
    border: 0;
    border-bottom: 1px solid white;
    &__placeholder,
    &__field__placeholder {
      color: inherit;
    }
  }
}
/* update-end author:sunjianlei date:20191220 for: 解决全局样式冲突问题 */
/* update_end author:zhaoxin date:20191129 for: 让搜索框颜色能随主题颜色变换*/
</style>

<style scoped>
.logout_title {
  color: inherit;
  text-decoration: none;
}
</style>